This allows hiding nodes of invisible widgets.
And that in turn makes sure :nth-child() works as expected.
return gtk_css_node_init_matcher (node, matcher);
}
+static GtkCssNode *
+get_previous_visible_sibling (GtkCssNode *node)
+{
+ do {
+ node = gtk_css_node_get_previous_sibling (node);
+ } while (node && !gtk_css_node_get_visible (node));
+
+ return node;
+}
+
+static GtkCssNode *
+get_next_visible_sibling (GtkCssNode *node)
+{
+ do {
+ node = gtk_css_node_get_next_sibling (node);
+ } while (node && !gtk_css_node_get_visible (node));
+
+ return node;
+}
+
static gboolean
gtk_css_matcher_node_get_previous (GtkCssMatcher *matcher,
const GtkCssMatcher *next)
{
GtkCssNode *node;
- node = gtk_css_node_get_previous_sibling (next->node.node);
+ node = get_previous_visible_sibling (next->node.node);
if (node == NULL)
return FALSE;
if (node == NULL)
return FALSE;
- node = gtk_css_node_get_previous_sibling (node);
+ node = get_previous_visible_sibling (node);
}
if (a == 0)
while (node)
{
b++;
- node = gtk_css_node_get_previous_sibling (node);
+ node = get_previous_visible_sibling (node);
}
return b % a == 0;
if (node == NULL)
return FALSE;
- node = gtk_css_node_get_next_sibling (node);
+ node = get_next_visible_sibling (node);
}
if (a == 0)
while (node)
{
b++;
- node = gtk_css_node_get_next_sibling (node);
+ node = get_next_visible_sibling (node);
}
return b % a == 0;
if (node->parent)
{
- if (invalid)
+ if (invalid && node->visible)
gtk_css_node_set_invalid (node->parent, TRUE);
}
else
cssnode->decl = gtk_css_node_declaration_new ();
cssnode->style = g_object_ref (gtk_css_static_style_get_default ());
+
+ cssnode->visible = TRUE;
}
static void
else
{
g_object_unref (node);
- gtk_css_node_set_children_changed (node->parent);
+ if (node->visible)
+ gtk_css_node_set_children_changed (node->parent);
}
node->parent = parent;
if (parent)
{
- gtk_css_node_set_children_changed (parent);
+ if (node->visible)
+ gtk_css_node_set_children_changed (parent);
g_object_ref (node);
- if (node->invalid)
+ if (node->invalid && node->visible)
gtk_css_node_set_invalid (parent, TRUE);
}
else
return cssnode->style;
}
+void
+gtk_css_node_set_visible (GtkCssNode *cssnode,
+ gboolean visible)
+{
+ if (cssnode->visible == visible)
+ return;
+
+ cssnode->visible = visible;
+
+ if (cssnode->parent)
+ gtk_css_node_set_children_changed (cssnode->parent);
+}
+
+gboolean
+gtk_css_node_get_visible (GtkCssNode *cssnode)
+{
+ return cssnode->visible;
+}
+
void
gtk_css_node_set_widget_type (GtkCssNode *cssnode,
GType widget_type)
child;
child = gtk_css_node_get_next_sibling (child))
{
- gtk_css_node_validate (child, timestamp, changes);
+ if (child->visible)
+ gtk_css_node_validate (child, timestamp, changes);
}
_gtk_bitmask_free (changes);
GtkCssChange pending_changes; /* changes that accumulated since the style was last computed */
+ guint visible :1; /* node will be skipped when validating or computing styles */
guint invalid :1; /* node or a child needs to be validated (even if just for animation) */
guint children_changed :1; /* the children changed since last validation */
};
GtkCssNode * gtk_css_node_get_previous_sibling(GtkCssNode *cssnode);
GtkCssNode * gtk_css_node_get_next_sibling (GtkCssNode *cssnode);
+void gtk_css_node_set_visible (GtkCssNode *cssnode,
+ gboolean visible);
+gboolean gtk_css_node_get_visible (GtkCssNode *cssnode);
+
void gtk_css_node_set_widget_type (GtkCssNode *cssnode,
GType widget_type);
GType gtk_css_node_get_widget_type (GtkCssNode *cssnode);
result = g_object_new (GTK_TYPE_CSS_WIDGET_NODE, NULL);
result->widget = widget;
+ gtk_css_node_set_visible (GTK_CSS_NODE (result),
+ gtk_widget_get_visible (widget));
return GTK_CSS_NODE (result);
}
gtk_widget_queue_compute_expand (widget->priv->parent);
}
+ gtk_css_node_set_visible (widget->priv->cssnode, TRUE);
+
g_signal_emit (widget, widget_signals[SHOW], 0);
g_object_notify (G_OBJECT (widget), "visible");
gtk_widget_queue_compute_expand (widget);
}
+ gtk_css_node_set_visible (widget->priv->cssnode, FALSE);
+
g_signal_emit (widget, widget_signals[HIDE], 0);
if (!gtk_widget_is_toplevel (widget))
gtk_widget_queue_resize (widget);